## **Homework 3 – Pipelined THUMB CPU**

Due Nov. 15, 2016

The course ftp side has RTL codes of a pipelined microprocessor that can execute 16-bit THUMB instructions. The following lists the THUMB instruction encoding.

| Instruction classes (indexed by op)                                                                            | 15 | 14 | 13 |    | 11       |                        | 9                                | 8    |                | 6      | 5     | 4            | 3         | 2   | 1 0         |
|----------------------------------------------------------------------------------------------------------------|----|----|----|----|----------|------------------------|----------------------------------|------|----------------|--------|-------|--------------|-----------|-----|-------------|
| LSL   LSR                                                                                                      | 0  | 0  | 0  | 0  | ор       |                        | immed5 Lm L                      |      |                |        |       | Ld           |           |     |             |
| ASR                                                                                                            | 0  | 0  | 0  | 1  | 0        |                        |                                  | ned5 |                |        |       | Lm           |           |     | Ld          |
| ADD   SUB                                                                                                      | 0  | 0  | 0  | 1  | 1        | 0                      | op                               |      | Lm             |        |       | Ln           |           |     | Ld          |
| ADD SUB                                                                                                        | 0  | 0  | 0  | 1  | 1        | 1 op imme              |                                  |      | nmed3          |        | Ln    |              |           | Ld  |             |
| MOV CMP                                                                                                        | 0  | 0  | 1  | 0  | op       | L                      | Ld/Ln immed8                     |      |                |        |       |              |           |     |             |
| ADD   SUB                                                                                                      | 0  | 0  | 1  | 1  | op       | Ld                     |                                  |      |                | immed8 |       |              |           |     |             |
| AND   EOR   LSL   LSR                                                                                          | 0  | 1  | 0  | 0  | 0        | 0                      | 0                                | 0    | op             |        |       | m/Ls         |           |     | Ld          |
| ASR   ADC   SBC   ROR                                                                                          | 0  | 1  | 0  | 0  | 0        | 0                      | 0                                | 1    | op             |        |       | m/Ls         |           |     | Ld          |
| TST   NEG   CMP   CMN                                                                                          | 0  | 1  | 0  | 0  | 0        | 0                      | 1                                | 0    | op             |        |       | Lm           |           | L   | d/Ln        |
| ORR   MUL   BIC   MVN                                                                                          | 0  | 1  | 0  | 0  | 0        | 0                      | 1                                | 1    | op             | 0      |       | Lm           |           |     | Ld          |
| CPY Ld, Lm                                                                                                     | 0  | 1  | 0  | 0  | 0        | 1                      | 1                                | 0    |                | 0      |       | Lm           | ,         |     | Ld<br>Ld    |
| ADD   MOV Ld, Hm<br>ADD   MOV Hd, Lm                                                                           | 0  | 1  | 0  | 0  | 0        | 1                      | op                               | 0    |                | 0      |       | m & '.<br>Lm | ′         | 1.1 | La<br>d & 7 |
| ADD   MOV Hd, Hm                                                                                               | 0  | 1  | 0  | 0  | 0        | 1                      | op                               | 0    |                | 1      |       | и<br>т & 1   | 7         |     | d & 7       |
| CMP                                                                                                            | 0  | 1  | 0  | 0  | 0        | 1                      | ор<br>0                          | 1    |                | 1      |       | m & '        | _         | 11  | Ln          |
| CMP                                                                                                            | 0  | 1  | 0  | 0  | 0        | 1                      | 0                                | 1    |                | 0      |       | Lm           |           | Н   | n & 7       |
| CMP                                                                                                            | 0  | 1  | 0  | 0  | 0        | 1                      | 0                                | 1    |                | 1      |       | m & '        | 7         |     | n & 7       |
| BX   BLX                                                                                                       | 0  | 1  | 0  | 0  | 0        | 1                      | 1                                | 1    | ор             |        | Rn    |              |           | 0   | 0 0         |
| LDR Ld, [pc, #immed*4]                                                                                         | 0  | 1  | 0  | 0  | 1        |                        | Ld                               | _    | o <sub>F</sub> |        |       | imm          | ed8       |     |             |
| STR   STRH   STRB   LDRSB pre                                                                                  | 0  | 1  | 0  | 1  | 0        | 01                     |                                  |      | Lm             |        |       | Ln           |           |     | Ld          |
| LDR   LDRH   LDRB   LDRSH pre                                                                                  | 0  | 1  | 0  | 1  | 1        | 01                     |                                  |      | Lm             |        |       | Ln           |           |     | Ld          |
| STR   LDR Ld, [Ln, #immed*4]                                                                                   | 0  | 1  | 1  | 0  | op       |                        | in                               | ımed | 5              |        |       | Ln           |           |     | Ld          |
| STRB   LDRB Ld, [Ln, #immed]                                                                                   | 0  | 1  | 1  | 1  | op       |                        | in                               | ımed | 5              |        |       | Ln           |           |     | Ld          |
| STRH   LDRH Ld, [Ln, #immed*2]                                                                                 | 1  | 0  | 0  | 0  | op       |                        | in                               | ımed | 5              |        |       | Ln           |           |     | Ld          |
| Instruction classes (indexed by op)  STR   LDR Ld, [sp, #immed*4]                                              | 15 | 0  | 0  | 12 | 11<br>op | 10                     | 9<br>Ld                          | 8    | 7              | 6      | 5     | 4            | 3<br>ned8 | 2   | 1           |
| ADD Ld, pc, #immed*4   ADD Ld, sp, #immed*4                                                                    | 1  | 0  | 1  | 0  | ор       |                        | Ld                               |      |                |        |       |              | ned8      |     |             |
| ADD sp, #immed*4   SUB sp,<br>#immed*4                                                                         | 1  | 0  | 1  | 1  | 0        | 0                      | 0 0 0 op immed7                  |      |                |        |       |              |           |     |             |
| SXTH   SXTB   UXTH   UXTB                                                                                      | 1  | 0  | 1  | 1  | 0        | 0                      | 1                                | 0    | oţ             | )      |       | Lm           |           |     | Ld          |
| REV   REV16     REVSH                                                                                          | 1  | 0  | 1  | 1  | 1        | 0                      | 1                                | 0    | oţ             | ,      |       | Lm           |           |     | Ld          |
| PUSH   POP                                                                                                     | 1  | 0  | 1  | 1  | op       | 1                      | 0                                | R    |                |        |       | regist       | er_li     | st  |             |
| SETEND LE   SETEND BE                                                                                          | 1  | 0  | 1  | 1  | 0        | 1                      | 1                                | 0    | 0              | 1      | 0     | 1            | op        | 0   | 0 (         |
| CPSIE   CPSID                                                                                                  | 1  | 0  | 1  | 1  | 0        | 1                      | 1                                | 0    | 0              | 1      | 1     | op           | 0         | а   | i j         |
| BKPT immed8                                                                                                    | 1  | 0  | 1  | 1  | 1        | 1                      | 1                                | 0    |                |        |       |              | 1ed8      |     |             |
| STMIA   LDMIA Ln!, {register-list}                                                                             | 1  | 1  | 0  | 0  | op       |                        | Ln                               |      |                |        | 1     | regist       | er_li.    | st  |             |
| B <cond> instruction_address+<br/>4+offset*2</cond>                                                            | 1  | 1  | 0  | 1  |          |                        | ond < 1110 signed 8-bit offset   |      |                |        |       |              |           |     |             |
| Undefined and expected to remain so                                                                            | 1  | 1  | 0  | 1  | 1        | 1                      | 1                                | 0    |                |        |       |              | x .       |     |             |
| SWI immed8                                                                                                     | 1  | 1  | 0  | 1  | 1        | 1                      | 1                                | 1    | l              |        |       |              | ned8      |     |             |
| B instruction_address+4+offset*2                                                                               | 1  | 1  | 1  | 0  | 0        |                        |                                  |      | signe          | d 11   | -bit  | offset       |           |     |             |
| BLX ((instruction+4+<br>(poff<<12)+offset*4) &~ 3)<br>This must be preceded by a branch prefix<br>instruction. | 1  | 1  | 1  | 0  | 1        |                        |                                  | ι    | ınsign         | ed 1   | 0-bit | t offse      | et .      |     | (           |
| This is the branch prefix instruction. It must be followed by a relative $B \ L$ or $B \ L \ X$ instruction.   | 1  | 1  | 1  | 1  | 0        |                        | signed 11-bit prefix offset poff |      |                |        |       |              |           |     |             |
| BL instruction+4+ (poff<<12)+ offset*2 This must be preceded by a branch prefix instruction.                   | 1  | 1  | 1  | 1  | 1        | unsigned 11-bit offset |                                  |      |                |        |       |              |           |     |             |

1. Trace the given Verilog RTL codes of the 16-bit pipelined THUMB processor, and use the given test bench tb\_thumb.v to verify the RTL code. Make necessary modifications for the codes to make them functionable in both RTL and gate-level.

2. Explain the function of the testbench in the file tb\_thumb.v.

## **References:**

1. S. Lee, *Advanced Digital Logic Design Using Verilog, State Machines, and Synthesis for FPGAs*, Nelson, 2006. (Chap. 9: Verilog code of the pipelined 16-bit THUMB CPU; Appendix A: THUMB instructions)